# A Short Introduction to Digital Logic Design



Z. Jerry Shi
Department of Computer Science and Engineering
University of Connecticut

Based on materials from Computer Organization: the Hardware/Software Interface by D. Patterson and J. Hennessy

#### **Outline**

- Gates and truth table (Appendix A.2)
- Build a combinational circuit with gates (Appendix A.3)
  - Common combinational circuit modules
  - Decoder and multiplexor
- Basic arithmetic logic unit ALU (Appendix A.5)

| Operator | Digital logic design | Python (bitwise) | Python (logical) |
|----------|----------------------|------------------|------------------|
| AND      | $X \cdot Y$          | X & Y            | and              |
| OR       | X + Y                | X   Y            | or               |
| NOT      | $\overline{X}$       | ~X               | not              |
| XOR      | $X \oplus Y$         | X ^ Y            |                  |

## How is a bit handled in digital circuit?

• The value of a bit is represented by the states of circuit elements

For example,



High voltage (e.g., 3.3V) indicates 1 and low voltage (e.g., 0V) indicates 0

Controlling the switches, we can set a signal/bit to 0 or 1

We build gates to compute on bits







#### Gates

- Gates are small circuit that computes on bits
  - A network of switches in each gate sets the output to 0 or 1



We can build any digital circuit with these three kinds of gates!

## Combinational versus sequential

Two types of circuit:

- Combinational circuit: the outputs depend on the current input values
- Sequential circuit: the outputs also depend on the history of inputs

  (clock)
  - Two identical sequential circuits may produce different outputs even if their current inputs are the same

### Truth table: NOT, AND, OR

- AND, OR, and NOT gates are combinational circuit
  - We can use truth tables to describe their functions
  - Pay attention to the new notation for NOT, AND, and OR operations

NOT:  $\overline{X}$ 

| X | NOT X |
|---|-------|
| 0 | 1     |
| 1 | 0     |

AND: X · Y

OR: X + Y

| X | Y | X AND Y |
|---|---|---------|
| 0 | 0 | 0       |
| 0 | 1 | 0       |
| 1 | 0 | 0       |
| 1 | 1 | (1)     |

| X | Y | X OR Y |
|---|---|--------|
| 0 | 0 | 0      |
| 0 | 1 | 1      |
| 1 | 0 | 1      |
| 1 | 1 | 1      |

## Logic expression and equations

• Logic function can be defined with logic equations

Variable = logic expression

Logic expression is also called Boolean expression.

Literal: a variable or its complement, for example, X,  $\overline{X}$ , Sel

Expression: literals combined by AND, OR, parentheses, and NOT

$$P \cdot \overline{Q} \cdot R \cdot (X + Y) \cdot (A + \overline{B} \cdot \overline{C}) + \overline{A} \cdot D$$
and
$$not$$

Logic Equation:

$$E = (A + \overline{B \cdot C}) \cdot D \qquad \text{Sum product}$$

# Boolean algebra

Logic expressions can be transformed with laws in Boolean algebra

|                   |                                                      | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \              |
|-------------------|------------------------------------------------------|------------------------------------------------------|
| Identity laws     | A + 0 = A                                            | $A \cdot 1 = A$                                      |
| Zero and One laws | A+1=1                                                | $A \cdot 0 = 0$                                      |
| Inverse laws      | $A + \overline{A} = 1$                               | $A \cdot \overline{A} = 0$                           |
| Commutative laws  | A + B = B + A                                        | $A \cdot B = B \cdot A$                              |
| Associative laws  | A + (B + C) = (A + B) + C                            | $A \cdot (B \cdot C) = (A \cdot B) \cdot C$          |
| Distributive laws | $A \cdot (B + C) = (A \cdot B) + (A \cdot C)$        | $A+(B\cdot C) = (A+B)\cdot (A+C)$                    |
| DeMorgan's laws   | $\overline{A + B} = \overline{A} \cdot \overline{B}$ | $\overline{A \cdot B} = \overline{A} + \overline{B}$ |

# Product term and sum term

Product term: A single literal or a product (AND) of two or more literals (and)  $A, \quad \overline{B}, \quad A \cdot B, \quad A \cdot B \cdot C, \quad D \cdot E \cdot \overline{F}$ 

Sum term: A single literal or a logical sum (OR) of two or more literals

- A,  $\overline{B}$ , A + B,  $X + Y + \overline{Z}$

# Assignments (and)

• 0 or 1 can be assigned to a variable

#### Only one assignment makes a product term evaluated to 1

For each product term, find the assignment that makes it equal to 1

### Question

What is the assignment that makes the following product term to be 1?

Write three bits, starting from A.

n A.
$$A \cdot B \cdot \overline{C} = 1$$

### **Sum of product**

Sum-of-product: A logical sum of product terms

$$A \cdot B \cdot C + C \cdot D + E$$

(1) Product

All logic expressions can be represented as a sum of product

If we have a logic expression, we can transform it into a sum of product

$$(A + B) \cdot (C + D) = A \cdot C + A \cdot D + B \cdot C + B \cdot D \longrightarrow Pragram$$

$$\begin{array}{c|c} \overline{X} & \overline{X} & \overline{X} \\ \overline{X} & \overline{Y} & \overline{X} & \overline{Y} \\ \overline{X} & \overline{Y} & \overline{Z}_{1} & \overline{Z}_{2} \\ \overline{X} & \overline{Y} & \overline{Y} & \overline{Y} \\ \overline{X} & \overline{Y} & \overline{Y} \\ \overline{X} & \overline{Y} & \overline{Y} & \overline{Y} \\ \overline{X} & \overline{Y} \\ \overline{X} & \overline{Y} & \overline{Y} \\ \overline{X} & \overline{Y} \\ \overline{X} &$$

# Write logic equation from truth table

We can write a logic equation from a truth table

Write a product term for each row where the function outputs 1

2. Write a sum of products by ORing all the product terms

Example: Write the logic equation for function G.

|   | $X \oplus Y$ |   | $\sqrt{}$ | _                      |        |
|---|--------------|---|-----------|------------------------|--------|
|   | X            | Y | G         |                        |        |
|   | 0            | 0 | 0         |                        | Step 1 |
| 7 | 0            | 1 |           | $\overline{X} \cdot Y$ |        |
|   | 1            | 0 |           | $X \cdot \overline{Y}$ |        |
|   | 1            | 1 | 0         |                        |        |

$$G = X \cdot \overline{Y} + \overline{X} \cdot Y$$
 Step 2

#### Example

• Write the logic equation for function F.

|   | X | Y | Z | F |                             |
|---|---|---|---|---|-----------------------------|
| 0 | 0 | 0 | 0 | 0 |                             |
| 1 | 0 | 0 | 1 | 1 | $\rightarrow \chi \chi_{Z}$ |
| 2 | 0 | 1 | 0 | 1 | > X Y Z                     |
| 3 | 0 | 1 | 1 | 0 | +                           |
| 4 | 1 | 0 | 0 | 1 | ->XYZ                       |
| 5 | 1 | 0 | 1 | 1 | > X \ Z                     |
| 6 | 1 | 1 | 0 | 0 | 4                           |
| 7 | 1 | 1 | 1 |   | SXXZ                        |
|   |   |   |   |   | V 🔾                         |
|   |   |   |   |   |                             |

We can number the rows with the binary number formed by bits X, Y, and Z

#### **Answer**

• Write the logic equation for function F.



### Implementation of Logic Circuit

• A sum of product can be implemented with two-level circuit.



Both A and  $\overline{A}$  are literals. This is still a two-level circuit. NOT is only needed at input

#### Two-level circuit

- All the combinational circuit can be implemented as two-level AND and OR gates
  - Direct implementation of sum of product



#### **Example of two-level circuit**

• Can you write the logic expressions for D, E, and F?



#### X in Truth Table

- X at output: Don't care
  - Designer can set the output to 0 or 1. Either is correct.
  - Designer picks 0 or 1, e.g., for simpler implementation
- X at input: The signal can be 0 or 1. It does not affect the output

|                        | _             |                   |   |                      |   |   |
|------------------------|---------------|-------------------|---|----------------------|---|---|
|                        |               | G                 | F | С                    | В | A |
|                        |               | 1                 | 0 | 0                    | 0 | 0 |
|                        |               | 0                 | 1 | 1                    | 0 | 0 |
|                        |               | 0                 | 1 | 0                    | 1 | 0 |
|                        |               | 1                 | 0 | 1                    | 1 | 0 |
| G can be either 0 or 1 |               | ⊙ X (             | 1 | 0                    | 0 | 1 |
| either 0 or 1          | $\rightarrow$ | $_{\mathcal{Q}}X$ | 0 | 1                    | 0 | 1 |
|                        |               | ⊘ X ø             | 1 | $\circ^{\mathbf{X}}$ | 1 | 1 |
|                        | -             | -                 |   |                      | - |   |

C can be either 0 or 1.

ABC = 110 and 111 have the same output

#### **Example: Implementation 1**

Set don't cares at output to 001.

| A | В | С | G |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | X | 1 |

 $A \cdot B$ 

Since C does not affect the output in this row, we do not include C in the product term

$$G = \overline{A} \cdot \overline{B} \cdot \overline{C} + \overline{A} \cdot B \cdot C + A \cdot B$$

### **Example: Implementation 2**

Set don't cares at output to 000.

| A | В | С | G |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | X | 0 |

$$G = \overline{A} \cdot \overline{B} \cdot \overline{C} + \overline{A} \cdot B \cdot C$$

## **Example: Implementation 3**

Another way to set don't cares

|   | $\langle V \rangle$ |   |   |
|---|---------------------|---|---|
| A | В                   | С | G |
| 0 | 0                   | 0 | 1 |
| 0 | 0                   | 1 | 0 |
| 0 | 1                   | 0 | 0 |
| 0 | 1                   | 1 | 1 |
| 1 | 0                   | 0 | 1 |
| 1 | 0                   | 1 | 0 |
| 1 | 1                   | 0 | 0 |
| 1 | 1                   | 1 | 1 |

Advantage: G does not depend on A

$$G = \overline{B} \cdot \overline{C} + B \cdot C$$

#### Decoder



Vec

*n*-bit input,  $2^n$ -bit output

One and only one output specified by input is asserted (i.e., 1)

Example: A 3 to 8 decoder.

Write a logic equation for Out6.





- Design a 1-2 decoder
  - S activates one of the output signals: Out1 or Out0
- Write the logic equation for Out1 and Out0



# Multiplexor (MUX)

Selector

Select one out of multiple data sources

Example: 2-1 multiplexor

Use 1 bit to select one out of two input. (if-then-else)



How can we implement the MUX with gates?

### **Example: implementation of 2-1 MUX**

#### Idea:

Use AND gates as switch

A 1-to-2 decoder decides which switch is on

OR gate combines the output of AND gates

This is a 1-bit 2-1 Mux. How do we design a 32-bit Mux?

MyHDL implementation:

cse3666/mux.py at master · zhijieshi/cse3666 (github.com)

- 10 . . . . .

# 32-bit 2-1 Multiplexor

- Just make 32 copies and get an array of 32 1-bit MUX
- All controlled by the same select signal





### **Example: 4-1 multiplexor**

Use 2-bit Sel to select one out of four. (if-then-else)

```
# MyHDL
@always_comb
def mux_logic():
    if sel == 0:
        z.next = a
    elif sel == 1:
        z.next = b
    elif sel == 2:
        z.next = c
    else:
        z.next = d
```



How can we implement it with basic gates?



#### **Example: 4-1 multiplexor**

Assume S1 and S0 are bits 1 and 0 in Sel.

Let us use E0, E1, E2 and E3 to indicate which branch is enabled.

$$E0 = \overline{S1} \cdot \overline{S0}$$
  $E1 = \overline{S1} \cdot S0$   $E1 = S0 \cdot \overline{S0}$   $E2 = S1 \cdot S0$ 

$$\overset{\text{(Z)}}{=} \underbrace{\frac{\text{E0}}{\text{S1}} \cdot \frac{\text{A}}{\text{S0}} \cdot \text{A} + \frac{\text{E1}}{\text{S1}} \cdot \frac{\text{B}}{\text{S0}} \cdot \text{B} + \frac{\text{E2}}{\text{C}} \cdot \frac{\text{C}}{\text{E3}} \cdot \frac{\text{D}}{\text{S0}} \cdot \text{C} + \frac{\text{S1}}{\text{S0}} \cdot \text{D}}$$

#### 1-bit full adder

add Rd, RS1, RSZ



|   | Inputs |         | Outp     | uts |                               |
|---|--------|---------|----------|-----|-------------------------------|
| а | b      | CarryIn | CarryOut | Sum | Comments                      |
| 0 | 0      | 0       | 0        | 0   | $0 + 0 + 0 = 00_{two}$        |
| 0 | 0      | 1       | 0        | 1   | $0 + 0 + 1 = 01_{two}$        |
| 0 | 1      | 0       | 0        | 1   | $0 + 1 + 0 = 01_{two}$        |
| 0 | 1      | 1       | 19 ab/   | 0   | $0 + 1 + 1 = 10_{two}$        |
| 1 | 0      | 0       | 0        | 1   | 1 + 0 + 0 = 01 <sub>two</sub> |
| 1 | 0      | 1       | 1 abc    | 0   | 1 + 0 + 1 = 10 <sub>two</sub> |
| 1 | 1      | 0       | Dabi     | 0   | $1 + 1 + 0 = 10_{two}$        |
| 1 | 1      | 1       | Cabo     | 1   | 1 + 1 + 1 = 11 <sub>two</sub> |

# Generating CarryOut

# abet abet abet abe

#### CarryOut

 $= a \cdot b \cdot \overline{CarryIn} + \underline{a \cdot b} \cdot CarryIn + \underline{\overline{a} \cdot b} \cdot CarryIn + \underline{a \cdot b} \cdot CarryIn$ 

 $= a \cdot b + a \cdot CarryIn + b \cdot CarryIn$ 



## Calculating sum

• From the truth table, we can write an equation for sum, using AND, OR, and NOT

$$Sum = \overline{a} \cdot \overline{b} \cdot c + \overline{a} \cdot b \cdot \overline{c} + a \cdot \overline{b} \cdot \overline{c} + a \cdot b \cdot c$$

• Or, we can use XOR gates:

Sum = 
$$a \oplus b \oplus c$$



In the earlier example, the equation for F is:

$$F = \overline{X} \cdot \overline{Y} \cdot Z + \overline{X} \cdot Y \cdot \overline{Z} + X \cdot \overline{Y} \cdot \overline{Z} + X \cdot Y \cdot Z$$

# Arithmetic and Logic Unit (ALU)

combining logic >> Cl

• ALU is the circuit that performs arithmetic and logic operations

We now have an adder

We can build a logic unit that supports AND and OR



The logic unit supports AND and OR. A 2-1 MUX selects either AND or OR result. How do we put them together?

#### 1-bit ALU

- Here is a 1-bit ALU that can perform AND, OR, and addition
  - All three results are generated, and only of them is selected



# **Integer Addition Example**



#### 32-bit ALU

 All 1-bit ALUs performs the same operation, specified by the same Operation signal

AND and OR are supported naturally

- Carry is chained for addition
  - ALU0 is the LSB





### How do we do subtraction?

## **Integer Subtraction Example**

To perform subtraction, we add the negation of the second operand

$$A - B = A + (-B)$$

Example: 7 - 6 = 7 + (-6)

```
7: 0000 0111
```

6: 0000 0110

# bits for 6 and 7 are provided

```
# flip bits in 6
# add one by setting C0 to 1
# green bits are not input
```

#### **Subtraction**

To negate a two's complement number, flip all the bits and add 1.



## Support for BEQ and BNE

How do we check if two 32-bit values are the same?

BEQ, BNE A == B

beg RS1, RS2, label (bne)



0x0000002

7 0x0000002



### ALU we will use

- Support the following operations:
  - AND, OR, add, sub
- ALU operation has 4 bits, specifying the operation ALU performs
  - See any patterns in ALU operation code?

Ubst

| ALU operation | Function |
|---------------|----------|
| 0000          | AND      |
| 0001          | OR       |
| 0010          | ADD      |
| 0110          | SUB      |
|               |          |



# **Common Design Goals**

- It works
- It is fast
- It is small
- It is energy efficient
- ... and more

## **Delay and Critical Path**

- Signal takes time to propagate from input to output
  - Cannot go faster than light
  - Many other factors affect the delay



• Critical path:

Credit: learnabout-electronics.org

The path from input to output that has the longest delay = most hardware

Can you identify the critical path of the 1-bit ALU?

#### 1-bit ALU



• How can we modify ALU to support XOR? XOR?



There are 10 digital locks, each controlled by an UNLOCK signal.

Only one of them can be unlocked at any time.

Which of the following modules is preferred to generate the

**UNLOCK** signals?

A. Decoder

B. Multiplexor

C. ALUX



Any digital logic can be built with AND, OR, and NOT gates.



B. False

## Many ways to describe a logic function

Truth table, logic expressions, circuit diagram, and actual circuit

A bubble denotes NOT



## **DeMorgan's laws**

- DeMorgan's laws on longer expressions
  - Invert all the terms
  - Change AND to OR (or OR to AND)

$$\overline{A \oplus B + C + \overline{D}} = \overline{A} \cdot \overline{B} \cdot \overline{C} \cdot D$$

$$\overline{A \cdot B \cdot \overline{C} \cdot \overline{D}} = \overline{A} + \overline{B} + C + D$$

Exercise: Convert the following logic expression to a form that does not have a NOT operator.



Transform the following logic expression to a sum of product.

$$A \cdot \overline{(B \cdot C)} \cdot \overline{(C + D)}$$

## Signal

- Typically, a physical signal is radio/electrical current/sound waves that carries information
- In digital circuit, we also use signal to refer to the path/wire/pin where a signal propagates
- A signal may correspond to one bit
  - The value is represented by the states of circuit elements (e.g., voltage)

A signal is asserted: signal is true or 1

A signal is deasserted: signal is false or 0

- A signal may carry multiple bits
  - For example, a bus is a collection of data lines